<template>
  <upload-excel :on-success="success" />
</template>

<script>
import { importEmployee } from '@/api/employees'
export default {
  methods: {
    async success ({ header, results }) {
      // header中的数据是中文 需要修改为后台需要的英文
      const userRelations = {
        '入职日期': 'timeOfEntry',
        '手机号': 'mobile',
        '姓名': 'username',
        '转正日期': 'correctionTime',
        '工号': 'workNumber'
      }

      // const arr = []
      // result.forEach(item => {
      //   const userInfo = {}
      //   Object.keys(item).forEach(key => {
      //     userInfo[userRelations[key]] = item[key] // 将原来中文的值赋值给英文
      //   })
      //   arr.push(userInfo)
      // })
      var newArr = results.map(item => {
        var userInfo = {}
        Object.keys(item).forEach(key => {
          if (userRelations[key] === 'timeOfEntry' || userRelations[key] === 'correctionTime') {
            //  后端接口限制不能是字符串
            userInfo[userRelations[key]] = new Date(this.formatDate(item[key], '/')) // 只有这样才能存入数据库
          } else {
            userInfo[userRelations[key]] = item[key]
          }
        })
        return userInfo
      })
      try {
        await importEmployee(newArr)
        this.$message.success('导入excel成功')
        this.$router.go(-1) // 回到上一个页面
      } catch (error) {
        this.$router.go(-1)
      }
    },
    // 转换execl的日期格式
    formatDate (numb, format) {
      const time = new Date((numb - 1) * 24 * 3600000 + 1)
      time.setYear(time.getFullYear() - 70)
      const year = time.getFullYear() + ''
      const month = time.getMonth() + 1 + ''
      const date = time.getDate() - 1 + ''
      if (format && format.length === 1) {
        return year + format + month + format + date
      }
      return year + (month < 10 ? '0' + month : month) + (date < 10 ? '0' + date : date)
    }
  }
}
</script>

<style>
</style>
